iT邦幫忙

2017 iT 邦幫忙鐵人賽
DAY 5
1
Modern Web

30天學會Vue.js系列 第 5

Day 5 Vue模板

  • 分享至 

  • xImage
  •  

今天要介紹Vue的模板語法,Vue使用HTML-based的模板語法,並將模板compile成virtual DOM,然後和vue物件中的data進行雙向綁定,這邊常會看到一個單字: reactivity,直譯的話是反應,我感覺意思大概有點像是DOM會對data的改變進行反應,Vue會自動計算更新DOM的最短路徑。

Vue其實也有提供JSX的Support,如果對JSX熟悉的話可以嘗試使用看看,這邊只介紹模板系統。

今天要介紹的是插入內容的語法。

文字

插入element的內容

<span>Message: {{ msg }}</span>

Vue預設會對內容進行雙向綁定,若不想這麼做的話可使用v-once這個元素屬性

<span v-once>This will never change: {{ msg }}</span>

這樣的話內容就只會被更新一次,不會隨著data的更新而更新

HTML

雙大括號的內容會以純文字的形式插入,如果想插入HTML的話要使用v-html屬性

<div v-html="rawHtml"></div>

但注意動態插入HTML會有XSS攻擊的風險,所以記住插入的HTML一定要是被信任的,且盡量避免讓使用者插入HTML

屬性

插入屬性的方式是v-bind:attr

<div v-bind:id="dynamicId"></div>

若綁定的資料型態是boolean的話,可以做屬性的切換

<button v-bind:disabled="someDynamicCondition">Button</button>

若值是false的話這個屬性會被移除

Javascript

你可以在模板語法中使用JS的語法

{{ number + 1 }}
{{ ok ? 'YES' : 'NO' }}
{{ message.split('').reverse().join('') }}
<div v-bind:id="'list-' + id"></div>

但只能是單行的敘述,像以下語法就是不合法的(不會執行)

<!-- this is a statement, not an expression: -->
{{ var a = 1 }}
<!-- flow control won't work either, use ternary expressions -->
{{ if (ok) { return message } }}

而且只能執行在白名單內的全域函式像是Math跟Date,無法使用自定義函式

以上是內容插入的部分,明天將繼續討論指令語法


上一篇
Day 4 Vue物件
下一篇
Day 6 Vue模板-2
系列文
30天學會Vue.js8
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言